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AGGRESSIVE CONTENT PRE-FETCHING DURING PRE-BOOT RUNTIME TO 
SUPPORT SPEEDY OS BOOTING 

TECHNICAL FIELD 

[0001] This disclosure relates generally to content pre-fetching, and in 
5 particular, relates to content pre-fetching during a pre-boot runtime to support speedy 
operating system booting. 

BACKGROUND INFORMATION 

[0002] In the field of computers, there has been a long felt need to reduce the 

10 boot time of computers. In fact, waiting for a computer to boot is an irritating nuisance 
almost universally acknowledged by all computer users. 

[0003] One reason for extended pre-boot runtimes are wasted processing 
cycles. Typically, during the pre-boot runtime the processor is executing in a single 
threaded environment. As such, the processor spends a considerable amount of time 

1 5 simply waiting or idle. For example, when initiaUzing a keyboard controller, the 

processor sends instructions to the keyboard controller to commence its initialization and 
then "busy" waits for the keyboard controller to complete. As mentioned, the typical 
pre-boot environment is single threaded. Therefore, during this busy wait period the 
processor does not proceed to the next execution task, but rather, waits until the 

20 keyboard controller completes its initialization. 

[0004] During the pre-boot runtime, the processor spends a considerable 
amount of time (e.g., 70%) busy waiting for any number of hardware devices, such as 
waiting for the hard disk drive to return requested data, waiting for input/output ("I/O") 
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ports, and the like. Furthermore, considerable time is lost busy waiting for user inputs 
(e.g., logon ID and password). All this busy waiting constitutes wasted processing 
power. 



2 



Attorney Docket No.: 42P17573 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0005] Non-limiting and non-exhaustive embodiments of the present invention 
are described with reference to the following figures, wherein like reference numerals 
refer to like parts throughout the various views unless otherwise specified. 
5 [0006] FIG. 1 is a block diagram illustrating a processing system to implement 

aggressive content pre-fetching during a pre-boot runtime, in accordance with an 
embodiment of the present invention. 

[00071 FIG. 2 is a flow chart illustrating a process to create a pre-fetch profile 
to implement aggressive content pre-fetching during a pre-boot runtime, in accordance 
10 with an embodiment of the present invention. 

[0008] FIG. 3 is a block diagram illustrating data flow during a profiling 
process, in accordance with an embodiment of the present invention. 

[0009] FIG. 4 is ? Hiagram ilhistrating a pre-fetch profile library including 
multiple pre-fetch profiles to implement aggressive content pre-fetching for multiple 
1 5 operating systems, in accordance with an embodiment of the present invention. 

[0010] FIG. 5 is a flow chart illustrating a process to pre-fetch content fi-om a 
data storage unit into system memory during a pre-boot runtime, in accordance with an 
embodiment of the present invention. 

[0011] FIG. 6 is a block diagram illustrating data flow during a pre-fetching 
20 process, in accordance with an embodiment of the present invention. 

[0012] FIG. 7 is a flow chart illustrating a booting process using pre-fetched 
content, in accordance with an embodiment of the present invention. 
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[0013] FIG. 8 is a block diagram illustrating data flow during a booting process 
where a portion of the boot content is pre-fetched, in accordance with an embodiment of 
the present invention. 

[0014] FIG. 9 a diagram of a system including an isometric view of a 
5 processing system to implement aggressive content pre-fetching during a pre-boot 
runtime, in accordance with an embodiment of the present invention. 
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DETAILED DESCRIPTION 

[001 5] Embodiments of a system and method for aggressive content pre- 
fetching during a pre-boot runtime to support speedy operating system ("OS") booting 
are described herein. In the following description numerous specific details are set forth 

5 to provide a thorough understanding of embodiments of the invention. One skilled in the 
relevant art will recognize, however, that the invention can be practiced without one or 
more of the specific details, or with other methods, components, materials, etc. In other 
instances, well-known structures, materials, or operations are not shown or described in 
detail to avoid obscuring aspects of the invention. 

1 0 [0016] Reference throughout this specification to "one embodiment" or "an 

embodiment" means that a particular feature, structure, or characteristic described in 
connection with the embodiment is included in at least one embodiment of the present 

invpntinn Thus, the annearances of the nhrases "in one embodiment" or "in an 

— . -, J ^ ^ ^ 

embodiment" in various places throughout this specification are not necessarily all 
15 referring to the same embodiment. Furthermore, the particular features, structures, or 

characteristics may be combined in any suitable manner in one or more embodiments. 
[0017] Throughout this specification, several terms of art are used. These 

terms are to take on their ordinary meaning in the art from which they come, unless 

specifically defined herein or the context of their use would clearly suggest otherwise. 
20 "Busy waiting" is defined herein as the act of intentionally stalling a processor or 

causing the processor to repeat a simple task for the purpose of waiting. 

[0018] In short, embodiments of the present invention include a system and 

method to advantageously use the busy waiting periods and/or idle time during the pre- 
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boot runtime to pre-fetch content from data storage units into system memory. 
Additionally, embodiments of the present invention include a system and method to 
determine which content should be pre-fetched during the busy wait periods. These and 
other embodiments are described in detail below. 

5 [0019] FIG. 1 is a block diagram illustrating a processing system 100 to 

implement aggressive content pre-fetching during a pre-boot runtime, in accordance with 
an embodiment of the present invention. The illustrated embodiment of processing 
system 100 includes one or more processors (or central processing units) 105, system 
memory 110, nonvolatile ("NV") memoryl 15, a hard disk drive ("HDD") 120, an 

10 optional communication link 125, and a chipset 130. 

[0020] The elements of processing system 100 are interconnected as follows. 
Processor 105 is communicatively coupled to system memory 1 10, NV memory 115, 

Ur^v pViincpt 1 '^0 tn spnH and to received 

llJ^A-' tUJ.*^ VWXXlAXX**AAAWfc*ViV/** .^—5 J - - - 

instructions thereto/therefrom. In one embodiment, NV memory 1 15 is a flash memory 
15 device. In other embodiments, NV memory 115 includes any one of read only memory 
("ROM"), programmable ROM, erasable programmable ROM, electrically erasable 
programmable ROM, or the like. In one embodiment, system memory 110 includes 
random access memory ("RAM"). In one embodiment, communication link 125 
includes a network interface card ("NIC"). HDD 120 may optionally include one or 
20 more of an integrated drive electronic ("IDE") hard disk, an enhanced IDE ("EIDE") 
hard disk, a redundant array of independent disks ("RAID"), a small computer system 
interface ("SCSI") hard disk, and the like. Although HDD 120 is illustrated as intemal 
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to processing system 100; however, HDD 120 may be external coupled to processing 
system 100. 

[0021] It should be appreciated that various other elements of processing 
system 100 have been excluded from FIG. 1 and this discussion for the purposes of 

5 clarity. For example, processing system 1 00 may further include a graphics card or 
additional HDDs or other persistent data storage devices (e.g., tape drive). Chipset 130 
may also include a system bus and various other data buses for interconnecting 
subcomponents, such as a memory controller hub and an input/output ("I/O") controller 
hub, as well as data buses for connecting peripheral devices to chipset 130. 

10 [0022] FIG. 2 is flow chart illustrating a process 200 to create a pre-fetch 
profile to implement aggressive content pre-fetching during a pre-boot runtime, in 
accordance with an embodiment of the present invention. Process 200 is described in 
4tu cm 1 v^n. -3 Jc o Wa/^v ^liaaram illnstratino Hata flow durineorocess 

200. FIG. 3 includes a data storage unit ("DSU") 301. DSU 301 represents any 
15 persistent data storage unit of processing system 100, such as HDD 120 and even NV 
memory 115. NV memory 1 15 has been illustrated as separate from DSU 301 for the 
sake of clarity. Furthermore for the sake of this discussion, software/firmware entities 
such as a profiler 305, a pre-fetch profile 3 1 5, an application program 320, an OS loader 
325, and an I/O agent 330 have been illustrated as external to the hardware components 
20 in which they are actually stored or executed. 

[0023] Returning to FIG. 2, in a process block 205, processing system 100 is 
power cycled. Power cycling processing system 100 includes a reset event or a power 
on event. In a processing block 210, processing system 100 executes early system 
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initialization tasks. Typically, early system initialization includes tasks such as a power 
on self test ("POST"), discovering memory resources (e.g., system memory 1 10, NV 
memory 1 15), initializing the memory resources, discovering platform hardware, 
initializing the platform hardware, and tiie like. 

5 [0024] In a decision block 215, profiler 305 determines whether a profile 

variable 310 is set. In short, profiler 305 acts to create a pre-fetch profile 315, as 
described below. Profiler 305 is enabled if profile variable 310 is set. Typically, 
profiler 305 will be initially stored in NV memory 1 15 and transferred into system 
memory 1 10 during operation of processing system 100. In one embodiment, profiler 

10 305 is loaded into system memory 1 1 0 in response to profile variable 3 1 0 being set. 
Alternatively, profiler 305 may be stored in any persistent data storage device, such as 
HDD 120. Furthermore, profiler 305 may be executed directiy fi'om NV memory 1 15 or 

PYpriition of nrocess 200. In 

one embodiment, pre-fetch variable 310 is a variable having one of two states (e.g., set 
15 and clear) stored within NV memory 1 15. hi other embodiments, profile variable 310 is 

stored witiiin any persistent memory device coupled to processor 105. If profile variable 

310 is set, process 200 continues to a process block 220. 

[0025] In process block 220, application program 320 or OS loader 325 

requests VO agent 330 to load content 335 stored on DSU 120 into system memory 110. 
20 I/O agent 330 is a software/firmware I/O interface between various hardware 

components of processing system 100 and software/firmware modules executing 

thereon. Software/firmware applications (e.g., application program 320, OS loader 325, 
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etc.) use the services provided by I/O agent 330 to transfer data or files fi:ora one 
location within processing system 100 to another. 

[0026] In one embodiment, I/O agent 330 is a block I/O executing within an 
extensible finnware framework standard known as the Extensible Firmware Interface 

5 ("EFI") (specifications and examples of which may be found at 

http://deveIoper.intel.com/technology/efi). EFI is a public industry specification that 
describes an abstract programmatic interface between platform firmware and shrink- 
wrap operating systems or other custom application environments. The EFI framework 
standard includes provisions for extending basic input output system ("BIOS") code 

10 functionality beyond that provided by the BIOS code stored in a platform's boot 

firmware device (e.g., NV memory 115). More particularly, EFI enables firmware, in 
the form of firmware modules and drivers, to be loaded 6om a variety of different 
: ^r,A oarsnnAmr f\ckBh Afvicpe ROA/fs varinii.<5 nersi.stent 

iCOUUiWa, lllVlUWlllg yXliAktM.J fcfWW****.**^ ^- , y t 

storage devices (e.g., hard disks, CD ROMs, etc.), and even over computer networks. 

1 5 [0027] Application program 320 may be any software/firmware entity 

executing on processing system 100. In one embodiment, application program 320 is a 
pre-boot application, which is loaded and executed during a boot-up phase (i.e., start-up 
phase) of processing system 100. Similarly, OS loader 325 is loaded from DSU 301 and 
executed during the boot-up phase of processing system 100. OS loader 325 is executed 

20 by processing system 100 to begin loading portions of an OS from DSU 301, such as the 
OS kemel, device drivers, apphcation programming interfaces ("APIs"), and the like, 
mto system memory 1 10. Each of application program 320 and OS loader 325 may 
request I/O agent 330 to load and/or execute content 335 from DSU 301, which may in 
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turn request I/O agent 330 to load other content from DSU 301. In fact, application 
program 320 and OS loader 325 are themselves content loaded from DSU 301. Content 
335 may include instructions, data, files, applications, drivers, and the like, loaded by 
processing system 100 into system memory 110 during a boot-up or boot-up phase of 

5 processing system 100. 

[0028] Returning to FIG. 2, in process block 220, one of application program 
320 and OS loader 325 requests I/O agent 330 to load a portion of content 335 from 
DSU 301 into system memory 110. hi a process block 225, profiler 305 records a source 
location of the load request into pre-fetch profile 3 15. In the illustrated case, the source 

10 location of the load request would be the location of content 335 stored on DSU 301. 
For example, the source location of content 335 could be a logical block address 
("LBA") on HDD 120, a memory address or an address location in NV memory 115. 

hlnrW 9'^0 T/D apent ?i?>0 executes the reauested load of 

^ J ^ - ^ ^^ * 

content 335 into system memory 110, illustrated by arrow 340. In a decision block 235, 
15 process 200 loops back to process block 220 and continues from there until all of content 
335 requested by application program(s) 320 or OS loader 325 has been loaded into 
system memory 1 1 0 and its source locations saved in pre-fetch profile 315. Once all of 
content 335 has been loaded, process 200 continues to a process block 240. In process 
block 240, profiler 305 clears profiler variable 310, signifying that profiling has 
20 completed and pre-fetch profile 3 1 5 is complete. In a process block 245, the pre-boot 
runtime is completed and the OS runtime commences. In one embodiment, the pre-boot 
runtime is completed upon execution of an "exit boot services" instruction. 
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[0030] Profiler 305 is illustrated in FIG. 3 within I/O agent 330 to indicate that 
in one embodiment, profiler 305 is a fiinctional component of I/O agent 330. However, 
in other embodiments, profiler 305 may be an independent entity lhat performs the 
functionality described herein in collaboration with I/O agent 330. 

5 [0031] Process 200 represents a setup process for creating pre-fetch profile 3 1 5 

for future use, as described below. In other words, process 200 is executed during an 
initial boot of a particular OS to create a pre-fetch profile of content loaded fi:om DSU 
301 for that particular OS. In subsequent boots, the pre-fetch profile created by process 
200 is used to pre-fetch content 335 into system memory 1 10 to hasten the boot-up phase 

1 0 for the particular OS. Processing 200 may be repeated randomly, at preset intervals, 
when it is determined that content 335 has substantially changed, or at a user request to 
update the pre-fetch profile. A pre-fetch profile for a particular OS may change over 

4r: i^r.fr>llo ■nc^^^.T tAot/^ViAo iiriHatpc nr 5irinlir.5»tinn!3 nn the OS Of BIOS. 

iiiiiw uo mw xxAhJi.M.xi.«^ ^j,^^,--., "r I ' 

[00321 FIG. 4 is a diagram illustrating a pre-fetch profile library 400 includmg 
15 multiple pre-fetch profiles, such as pre-fetch profile 315, in accordance with an 

embodiment of the present invention. The illustrated embodiment of pre-fetch profile 
library 400 includes a Windows^M OS pre-fetch profile 405, a Linux OS pre-fetch profile 
410, and an OS X profile 415 (representing various other current or after developed 
OS's). 

20 [0033] Pre-fetch profile library 400 may include any number of pre-fetch 

profiles, including only one. In one embodiment, when profiler 305 records source 
locations of content 335 into pre-fetch profile 315, pre-fetch profile 315 is saved to pre- 
fetch profile library 400 and indexed with the OS being booted by processing system 
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100 at the time. Thus, embodiments of the present invention support aggressive content 
pre-fetching in processing systems having multiple OS's or boot options. 

[0034] Any number of techniques may be used to encode pre-fetch profiles 
405, 410, and 415. For example, FIG. 4 illustrates a blocking method to encode pre- 

5 fetch profiles 405, 410, and 415. In this technique, contiguous LBAs on DSU 301 are 
grouped within a single entry. For example, entry 420 of pre-fetch profile 405 includes 
three values. A first value 421 of entry 420 is a source location of the first LBA of 
several contiguous LBAs. A second value 423 is a count indicating the number of 
contiguous LBAs. A third value 425 is a destination location. The destination location 

10 indicates to I/O agent 330 where the portion of the pre-fetched content 335 addressed by 
entry 420 should be loaded in system memory 1 10 (described below). 

[0035] Another technique of encoding pre-fetch profiles 405, 410, and 415 is a 
i. *u«j T T.,;«« rt«o-fr..r>n/» mptVinH pach T ,R A to he referenced within a 

Vll^-VU-VllV IIIWUIV*^. WUAAX^ V**^ VAX^i- *w V—.- . , 

pre-fetch profile has its own entry, each entry having two values— a source location and 
15 a destination location. Yet another technique of encoding pre-fetch profiles 405, 410, 
and 415 is called elevator scheduling. Elevator Scheduling may be used in conjunction 
with the blocking method and the one-to-one method to accelerate die pre-fetching 
process described below. Elevator scheduling organizes the entries of each of pre-fetch 
profiles 405, 410, and 415 according to the physical position of the LBAs on DSU 301. 
20 In an example where DSU 301 represents HDD 120, elevator scheduling would arrange 
the order of the entries of pre-fetch profiles 405, 410, and 415 to match the physical 
order of the source locations on HDD 120. Elevator scheduling minimizes read times 
from DSU 301 by minimizing travel distance of a read head. Yet another technique of 
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encoding a pre-fetch profile is probability profiling. Using probability profiling a single 
pre-fetch profile is generated for multiple operating systems. A pre-fetch profile using 
probability profiling gathers the most common LB As loaded during boot-up phases for 
several operating systems into one pre-fetch profile. The pre-fetch profile could be 
5 generated using various types of probability density fimctions. In one embodiment, a 
pre-fetch profile could be generated fi-om on a learned set of fetches based on a number 
of access patterns to DSU 301 over time. In one embodiment, the learned set of fetches 
could be acquired via Bayesian learning. In other embodiments, the learned set of 
fetches could be acquired via k-means and other learning techniques based on 
10 observation of disk patterns to determine a probability density fiinction of the most- 
probable accesses to DSU 301. 

[0036] FIG. 5 is a flow chart illustrating a process 500 to pre-fetch content 335 
A.^^ T^cTT mi infr. cA/cft»tvi m^mnr\/ 1 1 0 Hiirina nrp-hont nmtime. in accordance with 
an embodiment of the present invention. In short, process 500 is a technique to pre- 
15 fetching content 335 from DSU 301 using pre-fetch profile 615 (e.g., one of pre-fetch 
profiles 405, 410, and 415). Process 500 is also referred to as "warming the cache" in 
anticipation of a booting process 700, described below. Process 500 is described in 
connection with FIG. 6. FIG. 6 is a block diagram illustrating data flow during process 
500. 

20 [0037] Returning to process 200 illustrated in FIG. 2, if profile variable 310 is 

not set (i.e., cleared), then process 200 continues to an off-page reference A. Process 
500 continues fi-om off-page reference A. In a decision block 505, a prefetcher 605 
determines whether a pre-fetch variable 610 is set. to short, pre-fetcher 605 is a 

13 
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firmware agent which acts to preemptively load content 335 from DSU 301 into system 
memory 110 prior to content 335 being loaded in a natural course of the boot-up phase 
of processing system 100. Prefetcher 605 is enabled if pre-fetch variable 610 is set. In 
one embodiment, prefetcher 605 is loaded into system memory 110 from a persistent 

5 data storage device (e.g., NV memory 1 15, HDD 120, etc.) into system memory 1 10 and 
executed from there in response to pre-fetch variable 610 being set. 

[0038] In a process block 510, prefetcher 605 determines which pre-fetch 
profile from pre-fetch profile library 400 to access, hi one embodiment, pre-fetcher 605 
may simply access the one of pre-fetch profiles 405, 410, and 415, which corresponds to 

10 the last OS loaded by processing system 100. Alternatively, in one embodiment, pre- 
fetcher 605 may access and pre-fetch content of several of pre-fetch profiles 405, 410, 
and 415 dependent upon system idle time available during the boot-up phase. In a case 

wViPrP nrp-fptrh nrnfilp. lihrarv 400 inrliiHes nnlv one nre- fetch nrofile orocess block 510 

.. ^ — J — ^ ^ ^ ^ 

may be skipped. It should be appreciated that various other techniques may be 
1 5 implemented within the spirit of the present invention to determine which pre-fetch 
profile within pre-fetch profile library 400 to access. Referring to FIG. 6, pre-fetch 
profile 615 corresponds to the one of pre-fetch profiles 405, 410, and 415 accessed by 
prefetcher 605. 

[0039] In a decision block 515, prefetcher 605 waits until processor 1 05 is 
20 busy waiting or idle. When it is determined that processor 1 05 is busy waiting or idle, 
then in a process block 520 prefetcher 605 requests I/O agent 330 to preemptively load 
content 335 into system memory 110 from DSU 301. Prefetcher 605 determines what 
content to load from DSU 301 based on pre-fetch profile 615. Li a process block 525, 
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I/O agent 330 loads the requested content 335 into system memory 110. In one 
embodiment, I/O agent 330 loads the requested content 335 into a temporary boot 
memory 620 within system memory 1 10. In one embodiment, temporary boot memory 
620 is a boot services memory of the EFI standard framework. The boot services 
5 memory is valid only during the boot-up phase of processing system and upon entry into 
the OS runtime becomes stale, as the OS may reclaim the boot services memory at such 
time. 

[0040] In an embodiment of the present invention where prefetcher 605 is 
compliant with an EFI standard framework, a boot services stall routine is often called 
10 for processing system 100 to busy wait on a timer while processor 105 waits for a 

hardware entity to initialize, return results, or the like. In one embodiment of the present 
invention, the boot services stall routine is augment with code to call prefetcher 605 to 

rf-niiPQt nrppmntivft InaHs of rnntent duritie this busv wait neriod. In this manner, 

— ^ ^. ^. . ^ 

the busy wait or idle periods are not wasted. 

1 5 [0041] In a decision block 530, prefetcher 605 determine whether any entries 

remain in pre-fetch profile 615 which have not been preemptively loaded into system 
memory. If unloaded entries remain and the processing system 100 has not yet entered 
OS runtime (e.g., processor 105 has not yet executed an "exit boot services" instruction), 
then process 500 returns to decision block 515 and proceeds from there as described 

20 above. If on the other hand, all entries in pre-fetch profile 615 have been loaded or 
processing system 100 is about to complete the boot-up phase (i.e., no time remaining), 
then process 500 continues to a process block 535. In process block 535, the pre-boot 
runtime completes (e.g., processor 105 executes the "exit boot services" routine called 
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by OS loader 325 in the EFI standard framework, launching of the active partition's boot 
record in a legacy system or the like), the OS claims control over processing system 100, 
and commences OS runtime. 

[0042] Returning to decision block 505, if pre-fetch variable 610 is not set, 

5 then prefetcher 605 is not enabled and process 500 continues to a process block 540. In 
process block 540, processing system 100 completes a regular boot-up phase without 
pre-fetching content 335 from DSU 301 . In a process block 545, OS loader 325 loads 
components of an OS (e.g., OS kernel, device drivers, etc.) into system memory 1 10 and 
processing system 100 commences OS runtime (process block 550). 

1 0 [0043] FIG. 7 is flow chart illustrating a process 700 for booting processing 

system 100 using pre-fetched content, in accordance with an embodiment of the present 
invention. In one embodiment, process 700 executes concurrently with process 500. 
Process 700 is described cnnnertinn with Fin. R. FIG. 8 is a block diagram 
illustrating data flow during process 700. 

1 5 [0044] Process 700 continues from off-page reference A in FIG. 2. In a 

process block 705, one of application program 320 and OS loader 325 requests I/O agent 
330 to load content from DSU 301 into system memory 110. In a decision block 710, 
I/O agent 330 determines whether the requested content corresponds to content 810, 
which has already been preemptively loaded into temporary boot memory 620. Content 

20 810 represents a portion of content 335, which has already been preemptively loaded 
into system memory 1 10 via the techniques described in connection with process 500. 

[0045] If the requested content does match a portion of content 8 1 0, then 
process 700 continues to a process block 715. Li process block 715, I/O agent 330 

16 
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copies the requested content (i.e., the corresponding portion of content 810) from 
temporary boot memory 620 into runtime memory 815, illustrated with arrow 820. In 
one embodiment, the requested content is copied into a destination location within 
runtime memory 815 as requested by appUcation program 320 or OS loader 325. It 

5 should be appreciated that the techniques of the present invention may also be used to 
preemptively load application program 320 and OS loader 325 into system memory 1 10. 

10046] Returning to decision block 710, if the requested content does not 
correspond to a portion of content 810 (i.e., the requested content has not yet been 
preemptively loaded into system memory 1 10 or does not correspond to an entry within 

10 pre-fetch profile 615 and therefore will not be pre-fetched), then process 700 continues 
to a process block 720. In process block 720, I/O agent 330 fetches the requested 
content from DSU 301 and loads the requested content into system memory 1 10, 

wViftthftr the. rpniiestefi content IS to 

iliuatiuiwv*. i/jr uxxv/Tvo vfcAA** ^i^v. .^»,^w-.*«. — —J. i 

be executed during the OS runtime or simply to be temporarily executed during the boot- 
1 5 up phase will determine where in system memory I/O agent 330 loads the requested 
content. 

[0047] In a decision block 725, if the boot-up phase of processing system 100 
is not yet complete, then process 700 returns to decision block 710 and proceeds from 
there as described above. If the boot-up phase is complete, then process 700 exits the 
20 pre-boot runtime and commences execution within the OS runtime (process block 730). 

[0048] Embodiments of the present invention preemptively load (i.e., pre- 
fetch) content 335 from DSU 301 during a boot-up phase of processing system 100 
thereby resulting in a speedy OS boot. Embodiments of the present invention take 

17 
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advantage of the busy waiting and/or time which processor 105 would otherwise be idle 
during the pre-boot runtime to preemptively load content from DSU 301 into system 
memory 1 10. Copying the pre-fetched content 810 from one location within system 
memory 1 10 to another is many times faster than loading content from DSU 301 into 

5 system memory 1 1 0. Thus, by preemptively loading content from DSU 301 during 
otherwise wasted time, the boot-up phase of processing system 100 is decreased. 

[0049] FIG. 9 is a diagram of a system 900 including an isometric view of a 
processing system 905, in accordance with an embodiment of the present invention. 
Processing system 905 is one possible embodiment of processing system 100. The 

10 illustrated embodiment of processing system 905 includes a chassis 910, a monitor 915, 
a mouse 920 (or other pointing device), and a keyboard 925. The illustrated 
embodiment of chassis 910 fiirther includes a floppy disk drive 930, a hard disk 945, a 

«^rillrol• oiirM^t^/ (r^r\i c\^f\\\Try\ QnH Q lYintViPrKnflrH QSO nnmilfltpH with flnnrnnriate inteerated 

circuits including system memory 1 10, NV memory 1 15, and one or more processors 
15 105. 

[0050] Li one embodiment, a network interface card ("NIC") (not shown) is 
coupled to an expansion slot (not shown) of motherboard 950. The NIC is for 
connecting processing system 905 to a network 955, such as a local area network, wide 
area network, or the Internet, hi one embodiment network 955 is fiirther coupled to a 
20 remote computer 960, such that processing system 905 and remote computer 960 can 
communicate. 

[0051] Hard disk 945 may comprise a single unit, or multiple units, and may 
optionally reside outside of processing system 905. Monitor 915 is included for 
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displaying graphics and text generated by software and firmware programs run by 
processing system 905. Mouse 920 (or other pointing device) may be connected to a 
serial port, USB port, or other like bus port communicatively coupled to processor(s) 
105. Keyboard 925 is communicatively coupled to motherboard 950 via a keyboard 

5 controller or other manner similar to mouse 920 for user entry of text and commands. 
[0052] The above description of illustrated embodiments of the invention, 
including what is described in the Abstract, is not intended to be exhaustive or to limit 
the invention to the precise forms disclosed. While specific embodiments of, and 
examples for, the invention are described herein for illustrative purposes, various 

10 equivalent modifications are possible within the scope of the invention, as those skilled 
in the relevant art will recognize. 

[0053] These modifications can be made to the invention in light of the above 

aeiaiieU UCSWipUUa. mc icimo uo^u m ^Av*xAXA^ Mxw***^ - -- 

limit the invention to the specific embodiments disclosed in the specification and the 
1 5 claims. Rather, the scope of the invention is to be determined entirely by the following 
claims, which are to be construed in accordance with estabUshed doctrines of claim 
interpretation. 
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